package programmercarl.贪心.C19;

import java.util.ArrayList;
import java.util.List;

class Solution {
    public List<Integer> partitionLabels(String s) {
        List<Integer> res = new ArrayList<>();
        int[] edgs = new int[26];
        char[] chars = s.toCharArray();
        for (int i = 0; i < chars.length; i++) {
            edgs[chars[i] - 'a']=i;//保存最远位置
        }
        int idx=0;
        int last=-1;
        for (int i = 0; i < chars.length; i++) {
            idx =Math.max(idx,edgs[chars[i] - 'a']);//保存当前字符最大出现位置
            if (i==idx) {
                res.add(i-last);
                last=i;
            }
        }
        return res;
    }
}